草庐IT

php - 扩展 PHPUnit : adding a decorator

全部标签

javascript - Chrome 扩展 : load and execute external script

我无法将外部js脚本加载到我的chrome扩展中并执行。看起来与thisquestion相同,但我仍然无法弄清楚为什么它在我的情况下不起作用。我的想法是,我想在我的内容脚本中包含一些应该解析网页内容的默认函数。对于一些特定的网页,我想加载和使用特定的解析器,所以我尝试为一个网页加载适当的js脚本,这个脚本应该扩展默认解析器的功能。现在我只尝试从外部脚本执行代码,但有这样的错误:这是我的ma​​nifest.json:{"name":"Extensionname","version":"1.2","description":"Mychromeextension","browser_act

javascript - 如何在 Chrome 扩展内容脚本中获取错误堆栈跟踪?

有一个GoogleChromeextension使用contentscript处理所有标签页上发生的JS错误。但问题是,没有任何一种获取错误堆栈跟踪的常用方法不起作用。比如在Chrome扩展的contentscript中有一段代码:window.addEventListener('error',function(event){console.log(event.error.stack);//event.errorwillbenull},false);如果我在网页中调用此代码,那么event.error将包含具有stack属性的Error对象。尝试使用以下方法获取堆栈跟踪时遇到同样的问题

javascript - Safari 扩展中的当前 URL

safari.application.activeBrowserWindow.activeTab.url始终是undefined。知道为什么会这样吗? 最佳答案 我的印象是,当加载的页面在ExtensionWebsiteAccess中未被“允许”时,就会发生这种情况。扩展配置的一部分。Onlythewebsitesyouchoosehavewebcontentinjectedintothem,andonlythosewebsitescanbemanipulatedusingthetabobject’sproperties,sucha

javascript - 超简单的 Chrome 扩展不会将 EventListener 添加到按钮 onclick 事件

所以我正在测试创建一个chrome扩展。我知道使用Manifestv2你不能在popup.html中使用javascript。所以,我将javascript移到了一个单独的文件popup.js中。我试图在弹出窗口中添加一个简单的按钮来调用helloworld警报,但它根本不起作用。此外,Chrome的InspectElement调试器没有显示任何错误。popup.htmlTestpopup.jsfunctionmyAlert(){alert('helloworld')}window.onload=function(){document.addEventListener('DOMCont

javascript - Chrome 扩展内容脚本可以访问 window.opener 吗?

在我的扩展程序中,我试图确定一个新选项卡是否是由另一个选项卡作为弹出窗口创建的,如果是,是哪个选项卡。我想我可以使用内容脚本中的window.opener来帮助解决这个问题。但看起来window.opener在内容脚本中无法正常工作。当我手动创建一个选项卡时,它的window.opener正如预期的那样为null。当一个选项卡被另一个选项卡创建为弹出窗口时,它的window.opener是未定义的。我可以由此推断该选项卡是作为弹出窗口创建的,但我无法使用它来确定哪个选项卡创建了新选项卡。这是一个已知问题吗?有人知道任何解决方法吗? 最佳答案

javascript - 如何从网页打开 Chrome 扩展选项页面?

我的Chrome扩展有一个contentscript使用以下代码将HTML注入(inject)页面:varoptionsUrl=chrome.extension.getURL("src/options/options.html");varcontent='Options';这会产生:Options当我单击该链接时,它会打开一个新的浏览器选项卡仅此而已。如果我将href属性chrome-extension://gdocgfhmbfbbbmhnhmmejncjdcbjkhfc/src/options/options.html粘贴到地址栏中,我会看到我的Chrome扩展程序的选项页面正确显示

javascript - Chrome 扩展 setTimeout 无法正常工作

我在这里的第一篇文章=]。我正在构建一个chrome扩展,我正在递归地使用setTimeout。我注意到,如果我将它设置为最多13秒,它会起作用,但如果我将它设置为14秒以上,它就不起作用。这是我的background.js中的示例functionstart(){vartimeout=setTimeout(function(){start();},1000*15);alert('test');}chrome.webNavigation.onCompleted.addListener(function(o){start();},{url:[{urlContains:'http://www

javascript - 使用 Firefox 扩展插入 CSS

我正在构建一个Firefox扩展,可以将HTML元素添加到网站的某些页面。我想让它插入一个自定义CSS文件来设置这些元素的样式。如果我在页面上直接插入带有CSS的标签,它会起作用,但这是一个不太理想的解决方案。有没有办法让它加载和解析CSS文件,就好像我在header中使用了标签一样,还是我以某种方式内联了它? 最佳答案 chrome://将无法工作,因为不允许您插入的页面访问其域外的文件(包括chromeURI)。即使您是插入链接的人也是如此,因为链接仍然在目标页面的上下文中执行。相反,您有两个选择:您可以在list中定义资源协议

javascript - 扩展EventEmitter时如何解析 'this is not defined'?

这个问题在这里已经有了答案:"UncaughtReferenceError:thisisnotdefined"inclassconstructor(1个回答)关闭6年前。以下代码失败:varEventEmitter=require('events');classFooextendsEventEmitter{constructor(){this.name='foo';}print(){this.name='hello';console.log('world');}}varf=newFoo();console.log(f.print());并打印错误this.name='foo';^Ref

javascript - 在 javascript 中扩展 ActiveXObject

我想添加一些功能来跟踪对JavaScript中ActiveX对象方法的某些调用。我通常这样创建我的activeX对象:vartconn=newActiveXObject("Tconnector");每次在tconn和该activeX控件的所有其他实例上调用open方法时,我都需要记录。我无法修改tconn的原型(prototype),因为它没有原型(prototype)!我认为我可以创建一个虚拟ActiveXObject函数,它创建一个代理对象来代理对真实对象的调用。你能帮我做吗?注意:编写直接包装器是不可能的,因为在应用程序中已经有数千次对此activeX的调用。